草庐IT

MySQL 慢查询及SQL执行时间监控

全部标签

sql - has_many :through 的索引

假设您有两个模型,User和City,由第三个模型CityPermission加入:classCityPermission:city_permissionsendclassUser:city_permissionsend目前,我使用以下迁移代码片段创建连接表和表索引:create_table:city_permissionsdo|t|t.integer:user_id,:city_idt.other_fields...endadd_index(:city_permissions,:user_id)add_index(:city_permissions,:city_id)这些是要创建的最

ruby-on-rails - 我应该将我的数据库查询测试放在 Rails 中的什么位置?

我来自Spring/hibernate背景。我注意到Rails没有dao和服务层。这确实加快了开发速度,但有时我不知道将测试放在哪里。现在,我一直在将我的模型方法和验证测试放在主要模型规范中。这个文件已经相当大了。测试查询的“标准”位置在哪里?我可以想象自己制作了大量固定装置/虚拟数据以确保我的查询按预期工作(可能是一个更好的主意,因为我是Rails的新手)。这些对于基本模型逻辑和验证测试来说并不是真正需要的。如果您能提供一些关于将这些测试放在哪里的建议,使用rails测试查询的最佳方法(尤其是具有多个连接的查询!),也许还有一些基本准则,说明它与使用DBunit/spring进行测试

ruby-on-rails - MySql 上的 Rails 复选框存储为 null 或零

在我的Rails应用程序中,我有一个项目列表(如任务列表),每个项目都有几个复选框来设置参数。当我提交表单时,选中的框在数据库中存储为零,未选中的存储为空。问题是:有办法配置吗?将数据存储在更传统的0或1上,因为我认为将null存储为false并将0存储为true有点令人困惑,特别是如果另一个应用程序(如C应用程序)需要读取数据。 最佳答案 假设您正在使用的属性是club_member,如“您是club_member吗?”。请注意,在Ruby/Rails中,它现在的工作方式是,ifmodel.club_member如果未选中(值为n

sql - 是否可以在 Sequel 中批量更新?

是否可以使用Sequel在一次调用中进行多次更新??例如,在我的服务器上进行大约200次更新可能需要几分钟,但如果我伪造一个SQL查询,它会在几秒钟内运行。我想知道Sequel是否可以用来伪造那个SQL查询,或者更好的是,自己完成整个操作。 最佳答案 我遇到的解决方案涉及update_sql方法。它不是自己执行操作,而是输出原始SQL查询。要批量更新多个更新,只需将它们与;连接起来即可。在此期间,使用结果字符串调用run方法,一切就绪。批处理解决方案比多次更新快得多。 关于sql-是否可

ruby - 使用 twitter gem 回复你时间轴上的推文

我正在尝试从我的Twitter时间轴创建一个简单的回复,但遇到了一些问题,作为一个ruby​​新手,我在理解文档方面遇到了问题。Twitter.mentions_timeline.eachdo|tweet|reply_to=tweet.from_user_name()#Twitter.update("@#{reply_to}Nottoday.")end目前就写到这些了,不多。不幸的是,这条推文在使用mentions_timeline时似乎没有任何from_user_name。我正在使用这个gem,但没有找到任何好的例子:https://github.com/sferik/twitter

ruby - 如何改善 jRuby 加载时间?

我必须等待相当长的时间(与我friend的机器相比)才能在jRuby上执行脚本,尤其是当我运行rake任务或测试时。我已经尝试过jRuby版本1.3.1和1.4.1有和没有ruby​​-debuggem,并且在每个配置中都出现了同样的问题。问题很简单:有什么方法可以改进jRuby加载过程吗?..或者我的jvm配置或jRuby安装有问题(我通过rvm-ruby​​版本管理器使用jRuby)? 最佳答案 您可以尝试以下几种方法:使用最新最好的JRuby版本(由于广泛的测试套件,即使是最前沿的gitmaster分支通常也相当稳定),它们不

ruby-on-rails - Rails - 如何更改 created_at 时间?

在我的Controller中我有:@konkurrencer=Rating.new(params[:kon])@konkurrencer.save@konkurrencer.konkurrencer.rating_score+=params[:kon][:ratings].to_i@konkurrencer.konkurrencer.ratings+=1@konkurrencer.created_at=Time.now.strftime("%Y-%m-%d00:00:00")@konkurrencer.save当我创建一个新项目时,它的created_at列是:2012-02-2716

Ruby sleep 到特定时间

我怎么能写,我的代码休眠不是例如5秒,而是直到达到机器上的某个时间。不是这样的:sleep(5)但是像这样:now=DateTime.Nowwhilenow!="14:40:03"sleep(0.5)end怎么做才是正确的? 最佳答案 require"time"sleep(Time.parse("14:40:03")-Time.now) 关于Rubysleep到特定时间,我们在StackOverflow上找到一个类似的问题: https://stackover

ruby-on-rails - Ruby on Rails 4 中的日期时间格式

我需要将其添加到我的RoR4应用程序中以设置默认时间、日期和日期时间格式。我遵循了本指南,但无法使其正常工作。我将它添加到application.rb但日期只会从2014-05-2707:05:00UTC更改为27/May/2014,我希望它是27/05/20145:00PM。http://blog.nicoschuele.com/posts/cheatsheet-to-set-app-wide-date-and-time-formats-in-rails#Date#----------------------------Date::DATE_FORMATS[:default]="%e

Ruby - 执行已过期

我有这样的ruby​​代码:begindoc=Nokogiri::HTML(open(url).read.strip)rescueException=>exlog.error"Error:#{ex}"end我得到的日志是:ERROR--:Error:executionexpired我想要block重新执行直到它成功。我该怎么做? 最佳答案 我会稍微扩展一下我的评论。您可以使用retry返回到begin:begindoc=Nokogiri::HTML(open(url).read.strip)rescueException=>exlo